<!DOCTYPE html>
<html lang="zh-CN">
    <!-- title -->


    

<!-- keywords -->



<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
    <meta name="author" content="文平夕">
    <meta name="renderer" content="webkit">
    <meta name="copyright" content="文平夕">
    
        <meta name="keywords" content="hexo,hexo-theme,hexo-blog">
    
    <meta name="description" content="">
    <meta name="description" content="Here&#39;s something encrypted, password is required to continue reading.">
<meta property="og:type" content="article">
<meta property="og:title" content="开篇">
<meta property="og:url" content="https://lgsfly.gitee.io/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/index.html">
<meta property="og:site_name" content="辄止的博客">
<meta property="og:description" content="Here&#39;s something encrypted, password is required to continue reading.">
<meta property="og:locale" content="zh_CN">
<meta property="article:published_time" content="2022-03-04T16:00:00.000Z">
<meta property="article:modified_time" content="2022-03-05T16:25:17.847Z">
<meta property="article:author" content="文平夕">
<meta name="twitter:card" content="summary">
    <meta http-equiv="Cache-control" content="no-cache">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <link rel="icon" href="/assets/myicon.ico">
    
    <title>开篇 · Arbuda&#39;s Blog</title>
    <!-- /*! loadCSS. [c]2017 Filament Group, Inc. MIT License */
/* This file is meant as a standalone workflow for
- testing support for link[rel=preload]
- enabling async CSS loading in browsers that do not support rel=preload
- applying rel preload css once loaded, whether supported or not.
*/ -->
<script>
    (function (w) {
        'use strict'
        // rel=preload support test
        if (!w.loadCSS) {
            w.loadCSS = function () {}
        }
        // define on the loadCSS obj
        var rp = (loadCSS.relpreload = {})
        // rel=preload feature support test
        // runs once and returns a function for compat purposes
        rp.support = (function () {
            var ret
            try {
                ret = w.document.createElement('link').relList.supports('preload')
            } catch (e) {
                ret = false
            }
            return function () {
                return ret
            }
        })()

        // if preload isn't supported, get an asynchronous load by using a non-matching media attribute
        // then change that media back to its intended value on load
        rp.bindMediaToggle = function (link) {
            // remember existing media attr for ultimate state, or default to 'all'
            var finalMedia = link.media || 'all'

            function enableStylesheet() {
                link.media = finalMedia
            }

            // bind load handlers to enable media
            if (link.addEventListener) {
                link.addEventListener('load', enableStylesheet)
            } else if (link.attachEvent) {
                link.attachEvent('onload', enableStylesheet)
            }

            // Set rel and non-applicable media type to start an async request
            // note: timeout allows this to happen async to let rendering continue in IE
            setTimeout(function () {
                link.rel = 'stylesheet'
                link.media = 'only x'
            })
            // also enable media after 3 seconds,
            // which will catch very old browsers (android 2.x, old firefox) that don't support onload on link
            setTimeout(enableStylesheet, 3000)
        }

        // loop through link elements in DOM
        rp.poly = function () {
            // double check this to prevent external calls from running
            if (rp.support()) {
                return
            }
            var links = w.document.getElementsByTagName('link')
            for (var i = 0; i < links.length; i++) {
                var link = links[i]
                // qualify links to those with rel=preload and as=style attrs
                if (
                    link.rel === 'preload' &&
                    link.getAttribute('as') === 'style' &&
                    !link.getAttribute('data-loadcss')
                ) {
                    // prevent rerunning on link
                    link.setAttribute('data-loadcss', true)
                    // bind listeners to toggle media back
                    rp.bindMediaToggle(link)
                }
            }
        }

        // if unsupported, run the polyfill
        if (!rp.support()) {
            // run once at least
            rp.poly()

            // rerun poly on an interval until onload
            var run = w.setInterval(rp.poly, 500)
            if (w.addEventListener) {
                w.addEventListener('load', function () {
                    rp.poly()
                    w.clearInterval(run)
                })
            } else if (w.attachEvent) {
                w.attachEvent('onload', function () {
                    rp.poly()
                    w.clearInterval(run)
                })
            }
        }

        // commonjs
        if (typeof exports !== 'undefined') {
            exports.loadCSS = loadCSS
        } else {
            w.loadCSS = loadCSS
        }
    })(typeof global !== 'undefined' ? global : this)
</script>

    <style type="text/css">
    @font-face {
        font-family: 'Oswald-Regular';
        src: url("/font/Oswald-Regular.ttf");
    }

    body {
        margin: 0;
    }

    header,
    footer,
    .back-top,
    .sidebar,
    .container,
    .site-intro-meta,
    .toc-wrapper {
        display: none;
    }

    .site-intro {
        position: relative;
        z-index: 3;
        width: 100%;
        /* height: 50vh; */
        overflow: hidden;
    }

    .site-intro-placeholder {
        position: absolute;
        z-index: -2;
        top: 0;
        left: 0;
        width: calc(100% + 300px);
        height: 100%;
        background: repeating-linear-gradient(-45deg, #444 0, #444 80px, #333 80px, #333 160px);
        background-position: center center;
        transform: translate3d(-226px, 0, 0);
        animation: gradient-move 2.5s ease-out 0s infinite;
    }

    @keyframes gradient-move {
        0% {
            transform: translate3d(-226px, 0, 0);
        }
        100% {
            transform: translate3d(0, 0, 0);
        }
    }
</style>

    <link rel="preload" href="/css/style.css?v=20221112" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <link rel="preload" href="/css/dark.css?v=20221112" as="style">
    <link rel="stylesheet" href="/css/dark.css">
    <link rel="stylesheet" href="/css/mobile.css?v=20221112" media="(max-width: 960px)">
    <link rel="preload" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <link rel="preload" href="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js" as="script">
    <link rel="preload" href="/scripts/main.js?v=20221112" as="script">
    <link rel="preload" href="/scripts/dark.js?v=20221112" as="script">
    <link rel="preload" href="/font/Oswald-Regular.ttf" as="font" crossorigin>
    <link rel="preload" href="https://at.alicdn.com/t/font_327081_1dta1rlogw17zaor.woff" as="font" crossorigin>
    <!-- algolia -->
    
    <!-- 百度统计  -->
    
    <!-- 谷歌统计  -->
    
<meta name="generator" content="Hexo 5.4.1"></head>

    <script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script>
    <script type="text/javascript">
        if (typeof window.$ == undefined) {
            console.warn('jquery load from jsdelivr failed, will load local script')
            document.write('<script src="/lib/jquery.min.js" />')
        }
    </script>
    
        <body class="post-body">
    
        <!-- header -->
        <header class="header header-mobile">
    <!-- top read progress line -->
    <div class="header-element">
        <div class="read-progress"></div>
    </div>
    <!-- sidebar menu button -->
    <div class="header-element">
        
            <div class="header-sidebar-menu">
        
            
                <div style="padding-left: 1px;">&#xe775;</div>
            
        </div>
    </div>
    <!-- header actions -->
    <div class="header-actions">
        <!-- theme mode switch button -->
        <span class="header-theme-btn header-element">
            <i class="fas fa-adjust"></i>
        </span>
        <!-- back to home page text -->
        <span class="home-link header-element">
            <a href=/>Arbuda's Studio.</a>
        </span>
    </div>
    <!-- toggle banner for post layout -->
    
        
            <div class="banner">
        
            <div class="blog-title header-element">
                <a href="/">Arbuda&#39;s Studio.</a>
            </div>
            <div class="post-title header-element">
                <a href="#" class="post-name">开篇</a>
            </div>
        </div>
    
</header>

        <!-- fixed footer -->
        <footer class="footer-fixed">
    <!-- back to top button -->
    <div class="footer-fixed-element">
        
            <div class="back-top back-top-hidden">
        
        
            <div>&#xe639;</div>
        
        </div>
    </div>
</footer>

        <!-- wrapper -->
        <div class="wrapper">
            <div class="site-intro" style="







    height:50vh;

">
    
    <!-- 主页  -->
    
        
    <!-- 404页  -->
            
    <div class="site-intro-placeholder"></div>
    <div class="site-intro-img" style="background-image: url(/intro/post-bg.jpg)"></div>
    <div class="site-intro-meta">
        <!-- 标题  -->
        <h1 class="intro-title">
            <!-- 主页  -->
            
                开篇
            <!-- 404 -->
            
        </h1>
        <!-- 副标题 -->
        <p class="intro-subtitle">
            <!-- 主页副标题  -->
            
                
            <!-- 404 -->
            
        </p>
        <!-- 文章页 meta -->
        
            <div class="post-intros">
                <!-- 文章页标签  -->
                
                    <div class= post-intro-tags >
    
    
</div>

                
                
                    <div class="post-intro-read">
                        <span>字数统计: <span class="post-count word-count">6</span>阅读时长: <span class="post-count reading-time">1 min</span></span>
                    </div>
                
                <div class="post-intro-meta">
                    <!-- 撰写日期 -->
                    <span class="iconfont-archer post-intro-calander">&#xe676;</span>
                    <span class="post-intro-time">2022/03/05</span>
                    <!-- busuanzi -->
                    
                        <span id="busuanzi_container_page_pv" class="busuanzi-pv">
                            <span class="iconfont-archer post-intro-busuanzi">&#xe602;</span>
                            <span id="busuanzi_value_page_pv"></span>
                        </span>
                    
                    <!-- 文章分享 -->
                    <span class="share-wrapper">
                        <span class="iconfont-archer share-icon">&#xe71d;</span>
                        <span class="share-text">Share</span>
                        <ul class="share-list">
                            <li class="iconfont-archer share-qr" data-type="qr">&#xe75b;
                                <div class="share-qrcode"></div>
                            </li>
                            <li class="iconfont-archer" data-type="weibo">&#xe619;</li>
                            <li class="iconfont-archer" data-type="qzone">&#xe62e;</li>
                            <li class="iconfont-archer" data-type="twitter">&#xe634;</li>
                            <li class="iconfont-archer" data-type="facebook">&#xe67a;</li>
                        </ul>
                    </span>
                </div>
            </div>
        
    </div>
</div>

            <script>
  // get user agent
  function getBrowserVersions() {
    var u = window.navigator.userAgent
    return {
      userAgent: u,
      trident: u.indexOf('Trident') > -1, //IE内核
      presto: u.indexOf('Presto') > -1, //opera内核
      webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
      gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
      mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
      ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
      android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器
      iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者安卓QQ浏览器
      iPad: u.indexOf('iPad') > -1, //是否为iPad
      webApp: u.indexOf('Safari') == -1, //是否为web应用程序，没有头部与底部
      weixin: u.indexOf('MicroMessenger') == -1, //是否为微信浏览器
      uc: u.indexOf('UCBrowser') > -1, //是否为android下的UC浏览器
    }
  }
  var browser = {
    versions: getBrowserVersions(),
  }
  console.log('userAgent: ' + browser.versions.userAgent)

  // callback
  function fontLoaded() {
    console.log('font loaded')
    if (document.getElementsByClassName('site-intro-meta')) {
      document
        .getElementsByClassName('intro-title')[0]
        .classList.add('intro-fade-in')
      document
        .getElementsByClassName('intro-subtitle')[0]
        .classList.add('intro-fade-in')
      var postIntros = document.getElementsByClassName('post-intros')[0]
      if (postIntros) {
        postIntros.classList.add('post-fade-in')
      }
    }
  }

  // UC不支持跨域，所以直接显示
  function asyncCb() {
    if (browser.versions.uc) {
      console.log('UCBrowser')
      fontLoaded()
    } else {
      WebFont.load({
        custom: {
          families: ['Oswald-Regular'],
        },
        loading: function () {
          // 所有字体开始加载
          // console.log('font loading');
        },
        active: function () {
          // 所有字体已渲染
          fontLoaded()
        },
        inactive: function () {
          // 字体预加载失败，无效字体或浏览器不支持加载
          console.log('inactive: timeout')
          fontLoaded()
        },
        timeout: 5000, // Set the timeout to two seconds
      })
    }
  }

  function asyncErr() {
    console.warn('script load from CDN failed, will load local script')
  }

  // load webfont-loader async, and add callback function
  function async(u, cb, err) {
    var d = document,
      t = 'script',
      o = d.createElement(t),
      s = d.getElementsByTagName(t)[0]
    o.src = u
    if (cb) {
      o.addEventListener(
        'load',
        function (e) {
          cb(null, e)
        },
        false
      )
    }
    if (err) {
      o.addEventListener(
        'error',
        function (e) {
          err(null, e)
        },
        false
      )
    }
    s.parentNode.insertBefore(o, s)
  }

  var asyncLoadWithFallBack = function (arr, success, reject) {
    var currReject = function () {
      reject()
      arr.shift()
      if (arr.length) async(arr[0], success, currReject)
    }

    async(arr[0], success, currReject)
  }

  asyncLoadWithFallBack(
    [
      'https://cdn.jsdelivr.net/npm/webfontloader@1.6.28/webfontloader.min.js',
      'https://cdn.bootcss.com/webfont/1.6.28/webfontloader.js',
      "/lib/webfontloader.min.js",
    ],
    asyncCb,
    asyncErr
  )
</script>

            <img class="loading" src="/assets/loading.svg" style="display: block; margin: 6rem auto 0 auto; width: 6rem; height: 6rem;" />
            <div class="container container-unloaded">
                <main class="main post-page">
    <article class="article-entry">
        <div class="hbe hbe-container" id="hexo-blog-encrypt" data-wpm="Oh, this is an invalid password. Check and try again, please." data-whm="OOPS, these decrypted content may changed, but you can still have a look.">
  <script id="hbeData" type="hbeData" data-hmacdigest="deb1896ed99acd68d37244b9eff9be90f335fb050ee7a1b200f05346690c5936">c8a22d5d15e6d8bbfb6ea7bf0d8ce57c974dc6d2034b5497b0ad28590cea59333d4a8ab2febcc8565ddfae218db04fa3e94d794a245f806fdd550890a5b1ed433f46e5d086c8fe47a754bb3aa363e8f60a3ca6e6ac478d7e301fd6efa2d01e838316fed110968ac453304c602e1670321cb441fdeefec0cef176d6785ce6f1a9c0b8d29af44fe91fc4d13ecbf95eadfad6b46ebb1d261558141a5802cbeefe7907e52934716ac0aa15b4f21cd5b984d7d48587a6f424391b098764a1ff56b31acc7f4bc43b04a718c7b4f6ceda927a54cdbe6ab449fe12fbc2c20dd22dd804e81bdd347c21065a6397d97483b0cf60acf6b4f9524039ae491f8e67668872fa5025960ac3e06f190a5db5fecc1b0d0b2a1e56047466b69f0489f3ea197a87fcae9d3ae98b2289583c3f5d0ef498dc37573c2a37e532696b84fd43ef91fcc9934bc6a54b21be49d08644eda05282d1cbeeef010df188a853f9c55e88125e02437eb126d8f57e601825521c38727ad6cffe9b997333ff51f1415f1a9bc358588118dfc36586497267310d824e9a7be4ca8d6628b892b6577746273f9534f161ac5dea5d69ee0313eb62357c5adee8654e51fd6810637cb2625f1e7aa3cc2fde4c55ee3e64bff5395aefc28241d35bbbe304429819e02eba0143936e5c815910c20c87e74061ba5e9bfe52997e3e078518ff6a061a9fa8cf0ee73eb80d2db9ff1aa6bd07b05a72ab2e8ed7d8c697d09e9cabf4c219885cac491b88d006e5d54866a04a29c30a375a0b4031028343a0fd30cff076e80549aa2a1c04735d7dd38450f5408a3d019aa78cab86295facf682e94097e31b7cbc1995c32e9e35d9179ac306ad97038c9621697d01c737f3c389fbfb6f5bd86d61d68245dec1ac584e71113a2a3a5f792a9516174fcacfde93c8b8785d5cfd27a113bf3d5b41f234da10d7b22ca07cb511419db84c22efb12a9df86f24a15c8a66be9446b0012336a2ba2a493429e1d5e563daa0e8f046d128913ecd7794c90b17ff93563690fbc6e14d48666b2a1b21ad7f1188b9dcf15c00b17019167ea0a9a3d667c73f48d7a9badaafb4c6f2da3b2b1fa718390d1591fbdfff2ad1cbc894f00acd72685917e2cdca99524de39e5a5cd0cdd8be8434938327896e2c6c63e3f5fe17bb7d681b7462c7a61efe082cb14647e1b0d6ffeda4408c7c2fdea5998f87d6c1f4b8e39ef10308e1d8622b428e28bb44f2856629b8b2bb5b45ec80c35ccdf7760704fcba62d62b407f2906b946632c8bbd46ac5c243d9b3d81fc2c3a4faca0000f389f48c7609b90f21cfb288936b29a75b6cedb1ac17ed7881ade2e5274ce66feec31c9079ca13a8676405c9123e3198f162b9abbe89fd0a66a7e7421866afd82da9b86e24382772eb35384c784dfe3cc7c06aa354ec283b49db0254c0f2ea2a42e26cf5cbd4aa1f4bfcbb96eca21daf79b27f60c2ab84276d4a0dd925188819451b9cbee11ee17f9cca8d43bf7d3fc1ef6243a9fcd753902b17780450be6cf15416515ff0558f010652017de7bcdfe9f47bf3e0f16ff7604751c5d1706b15be41e2b3eaa3a22c4723ef70b763cf7bc8aa18a4d289ba94278b6dd7fd954ed69766d085ff7491f37205e978dc070a6dd3dc856b9bf7e444560c1b88fb5de88ab3d5d505a86ceba67c0696a1229ee798e38e408eaff88d9444781fd865c517afe245bed3ef0170d1b7f7df3944a0acbb734c1c76774417bf2b9080f25e9a83dbf1ade157af6a3326c7143f963b4e704b7bdf6715864e7f82d928c56f2ff463a961f34f0ba7d95b846d24fc8a95e6b3358125b669362cd311c588410277525f3d43bf2bc957a793001bcbc12df9ca7a99aedeeaa35287f6570c9cdf2323561d3b089701f7a7568fc3393acfaa5f6b524ab1e1fc473bb0659359c08ea7397e1bf3466c6375abd288075e3e3a1ea0e36d6b4c997c3bbeb6dbbeba9f34f356451920036990991029181db872287a1172f6a280f1d0a7202a038794c45a67185108277798dc07288f7d1065fc6722604784a7bf1dea8b071eeb0253bbdfc0bad1ff8c16c354a24d8595c6a3c94f7ca42a41683955a4c574cd28316cc009767d9f02dc87233e4b5b58c5ff5ee759011b7d580198a395f3631494708cbb9157cfc1f457a1e297115de16d2bac0229d6bcc6b5fbf5f05410441a163fa9e5df8e20642be11a442bef250d8ba89c73b54fbd828e1ecdcc8ebbde672726b27d4a40f5054052235c5a5581a261e7e93ef29ab575c753da1aa73dc2ca72911f879fc5e383c51e24f56e75304b31c6b1d43dc73319c285a5480677fd3cd506b71eb7a61560f3d6c67432e7fda135a21e289fce5171a99367e6dca50474bb2a8d33dd6916a03c708ac12b84c59fbd4e665b928deec526266448f5ebd1725ce3300b65a8478d5e901cca61e5585848515e2c0ad448434bc3464528d7244995ad4811fde4bdea5b9b7f73870d9ccd4c1e879c5110a7e7bfb426f461a4891f21a28e7642fbc19921c435380ff1650325fae2eeeb94a168668ca61af88d710ed2f85982360103d0005e92ffce44cf360ecbc2cd7b380e5f0e65f7654abb97660ac7a4eabe3a59c229e65a671f5765ac0fc2c5b62b315ebc7eee79e9b2e7a137b5af6161323a5d3ccf61cbb22e5864d1837ffae9fe1992cd652d8a276f52e4c9b1a80dd69025a91908e1a643ab949f44d94ba7fa8ddd6e1aedbb4dcada1d9e7bb4454b3ee104e49a6a6b438e297556419d497c0407c168b88c0d1d67b022c30017a193c77f8cb6942d77f6d09e86335a9014fbd1d8b5e5894ce6d35f11f6a669c54acb2bff273c22ddc7d181dfe3313bc7ec5cad1cf44ba6b072c8191cfc078b9fdc1466bedde6240c8105cfa575c06976e1558bb46822c343d722c7bbcd987f408aeae60b171bae7f75c5fb833458e219dc06d481a63fa019d310a6f7cc8854f580246b6e348c2786de8775c5b940112f14e9388aa50da82e23124c34fb8bfafd1d2a519d28e6b142b0ad789c64617b470d2b9aa455d19536d0dd3582cdbf75abb9f54614faa9e274bed675f5ae900dd8826891f002cce6b5314b840097fb4dfa551028ce73a59e2bf2486fa3a534f96943e05681f84ee11709e264e7d050b9dc38abe32f554129f15fd2ab63079d44a197a51e7b4347ed3e624397de473ac16fd2e2f4b1fedbd4864848796a754f0ae0d3d524051802d6906f8078aa44573e1fbc770bbac025b88c3c154e05f54babebb0239b1d0c5a4c93dcea3b3066f7b964d8766e9932df5f201a6a9c9adfe43b88953f521a6635c584531e6f0b796df032800b8c48bfd9756e70d95cb9af6384c9841aed1f7487df94b27cc5627460651c0eaa20ffe49d8289ab12255a83d211a3b2d6a52da95d04a97cabb246c72324a7dee1a6441b3147a3f450da625a85eb4ac79d55f7e079874910e6d548aa04618f84aa5f8b6f16ce4e0aeedcc0792872a879a1cd55339064b2b60c98f3f554368d4932d011c8537c477dbafaa4d33798673920925e81384e0f45dbaa7f4b124a2f7a17f7a996cef3e8c05efa0f41faba38709549415e0d8bed727eba87ebaf3bd726b79cd494b2b0f498710ffb922ce61f89403efc7bf08d56c795acfc9642374e915877d9663ca960a583ea800d30e96689b2201e4b9eb704f8911f4bb598205c4d926913b74f7faf31f0b43199091b0b24fe74db99b145cb3c1cac9707f57dac28ad2ee5b8a1c46a614c1d1fe213dee51e0c3584ead43bf0d73022aad6d90da423a9d67bac99402304ccd81bc28fe0eb9948ad36f99fb92b6009593165a27caf1eded8e1d995f50988220d457b39755c5f3f97f54f96289fb86073f18bc5563f7c6f2106b64cc165d4b0ac9ae43e775d26c75d9f1feebdb9603f2a5db9364e2217dd7e6ead40ae5f3d4ca61d2a7dc01c30f0343f59db23c04e55402624f95afd6ea46c6ce4a18573e1ea1af05b2bc7c86c98536ffa2e8e46eac213da5d31c8720ce57cc227712e58756ec64ead1e9777923d6b4a064eb950d02f4a87532b3fa969219b84a8a6721f8c18c196b2c8818cf77879ff5fc4d29d69f3b1b9e9a34bade672b6aea54f56d6a87c18260efad708c8aed8f1572c3cf4c86bf5bba87aed5e23b9b0df6ff4daca1c8393c745768101b4f7c1fa2e08e7fe87509de7124b3ef0339e2fa4d5117b96cd024a2240a4b523ed203150d7e1209ccb3ea6eec83ec21092b0b65b4305b04b8dcf4b9d11a1ff825f8ce9dc7488553b1a09a307d52f403690e99d403c7b00f9e32e9b266bd5025359548a0592b5c7ea2f39f7b96dfda3dd0879371e25d6fbce99c7cb4afc793bd9ca1d0af82364d1a7fca150f32557dbe3520bc36ad42582b98a3df4f79f1cbe7ff9219ace2ca6e347eed7cd0437efbadfc7304717d5ab65f9a8a1b6bc09149f0bde42dc362ef4b9ce71b8d14312448f3230c3e3f823706f340bd8162781164f415d20041d471dbc0877ec7f3b7737dbc359e04da28820cf4e8746274fb4171218b9a1d87c2c6f49eed9a6257bcb79aacc7ba522573c055a88f8691e137f3c305f637acf826281e6a8a70bbf28cce01e2b5b1503c544989df47b5c1353eb897c6bd2b678658866445cff6fd9c5c118773449fb718bed43d34175f1d106b10047397f5c0542398d150a413a3661440288ea7ce7d5ecdd529362b40c16ed07b63bf8e7614ceeaebbbf8f2aa5a6ad769d9dbf8b98263bee1b93684f1b3b5efbe4d87273240566c1e6cadfd8fbf7982c1a9b7a6f5636f68c144bdb50f73626050df64aaa786aeec8e5570c20558c9dd0bff3f414e0b94e203d493b612313c88db6924970ad8d799de4d4e996972f8aaa8c79daca6a1d1984251f3133a7be050ba2108e48979ccadf87bbccf5983e9117d4f8bfe3c3882e405d7a4968c9a6f0b4481c32e1f5f48c5bb29c1c892ad38bc807999417d900a52c39730c3712370cbf7b98986f8a95bab69cb5b907df6e17aad637f07eea637545db3558158c8a816f3d775de6b8425eb5ad4edac154337a12473170a27af5f80b89bd3aae168162165114445adbaa9c980daa955d47f1c36dbab9923cb4ea6993258b7a5e2042d60af4a4884f32da21af107da930ddcdde4eb567cae24794654ae43911b5880850637dd95e780e6a95ea2ad8663c7c4d9ff6004e0136f1fe2b1a3b1e971e699d76fb0311bd02fa012fc21e8f852b682a0dd9822f46b24deaa37b0d0601d1cb22efefee91eebbe1d9de0d88df42e66584c4683bbf52a9ca804631a3235814a43b3b5858706815e3a96f8365e6810576d00314ea3437d56f61b25d50e485b6cea09112dfca7ce21d4df883f6fdba02f309562d840b3626d07a96f040ac650aec1d758a98fd34d7bdf439bd8b93a8551d0000a87633607efe0e6a1ffa1ad3f4f6f1e8bab890cc70fd96d158c159a38b85fb92467ac88e0dd727b8def78d63619e551d9269fbb233c91f00599245709b0f5a624a66d610ddb893c74fea38c0b73eff65c9bddef37b0e42a01c3c2181cd9637c1e326a54ba2018dbc4a672a732d77345c9d8183dd26bfea18952ba006e7b87320ad105b7dd7da2a6c31935002e8f1ba64acec6643200bbc4b8e1e8c65ce93198f3d082ce6a2571c65bc0487bc999e9944bfc39fdf8d87d23fde3b05869892f985d3b5a73519cc177f8421491d69cda136a27b1d23d6d8bf9bcf78a67c05d13b9a8e550681590d0a3d4ee34396f2b280ae66e7e04a5143dbd9bd7c20877ebea6344a712b32823cc60de391b386fdbc0c71359a889d2316356b35229a04061ed0f44925f0ce9ee1d4ee865c82f1a5c5d2cabc253011c79f4159234acf1720c9b1500d5948cb04ae28a59854295f42f07132068b7793dc8d385e9aaa26aefc0eeb372548fe8476c0cc0bf7e05d8932a92923ccd6440b621aaba07b40469dd66d14fe840c914246181e91b0e0127b5a66c13306b0a4d8ff593025da4719e2193df8211be5e5377e9d5173243189251a39368784748821e2e74d99db028b64d12e0d20048b524c679ca0942706e84bd0ff728f005235cbc963a792a57815f75460b3c91181c2eed4412dd00bf0c2d45438828cab4f4b1a68ec61b5a4075fea9eecee03f8bada8de368fbdbdaa14d737249cb1e9ae6021ee4c2af070c99a968a99a5ce17db6ebce8b5dc049e1d793aefdbd2f7c1cd3c8963adc6422fd90bb24730970f985b878bf9f21abea341f90eac511009efc84385d50469074d34f5bf4046005fc961eb5eaa24938723c4fad592a66bed4129a8210cd4aa90fc2d29ec14a4f6d49a5f93040e98001f41e1125e873513e96a84c3ff90ef459b1af6c2bdc7ba6062ecaff1cd968be1ea28342934a051eb5f7409c27f9b51b2eb1ee9b2f9d9575e5c0d0d0887f5f54d7a645d231a165c9d7b8efb548e0a9ca0bfc1880077c081f5ef52b1103cca213fca58bcb96cc9500d683e0c96f09e049aacbaaea51a0832a36b7ee4637f0a0c336958c99b4acd545853be3070b7a400a2e4a859f7e07d07f68c23e293d94a7787c0638eaf2c2d8bf61c09af50e850fba060339e3e92bb11b70261e4939e9453393894c62407b80793d5ad60de893fe877c2b4066b52b5379a996d8d735ac4abbcb3aa244bb81a9e1a66cfe55cb274b355246b094ec9c09a4dff8ebdf8549092b11f325be2c8946d5d856ef2dc7164db93607e77ad219b0167630bc64be4df1f0563e5202d3866c1d44a451f804a6c0383dd752876dcffbd5c8e0c9b5f4aa80d1773f7709a41a4fcb9c2ba8060c72c2d6c9f5cd669155f2f72e3db4ba6ff3e33e974c36122721306b763050cbbba18c7b07b8fb4ba6039b14705ff2d34fb53795300c257b42bb358cf86245801c990277fd61d2bb24c9a2c489a694ef15db86f1f509687991f5e5c69fc86ccacda4ee43b4a8b47ce70d32073f3b72bcc572f0dffa1eabff92f5b8e5600648b3888d1a578938c468b75c41731c000cf03f06d79ef24b5720f04c7e3fcbec31f8130a61bec6890a0d4338561bf8ed40753c6b146d3f4ceaf33cb37b45a26bfe978801c38dfc9c7840b70c20bdc5603811d38ea276d7c6469bff8930cb4363e962cad7f69f3d9aec5fe05a1278f9b465b9d94d88b5f50de1b19a48439ea30b4a713dcab977246f8eaec6af01a6060526457e5ef9a763e92ff069a01d53b4bd670d1c597f5f41670d9ba9275b2451b459ba5170e9a15212ea86cc6aa41736793807c552b5724a89e7c37efb706f5e568485b18072ecf794947d39cdf5b2f5b4eeaf8966bf362947f3370ac91952e521d4cfc946318278bd523c60e72881c7566a688c32ed497e493043f90a55d34493ecf25c906fedde4dae794ee354547b07ace4b78321b1d074e07be8b7c1f4d71bb93cbaf12b1d732f546c6e721f1c11f00335b746508f5a536e37a432d6a55663c1a9b1e2eaa40b01b916f927a9db709e74dfd0450b74aa2eed22601d26c578ef859ae0f6d558ae519e203369e3957321c4e33fea0c3a0f1ffdc8e0131c1e9e4a6bb3c856d5c27d07483451be68b01d663811791ff3580bb37222597b89d07a31bca8d931bd43a8ff715941ebe1f5b34945c6bda9d0f242becd57ed59d16eee5f4096da92110fa13a71fee7a97b2cea856defce490e57d9ac0e13916ab84ac71c63f9c11d0bbe851852f392afcd2ffcd02baa0f03f39f9f6a395e1f79fc1a29088fc2b7bbf01391e1adc65254b7c3fb66caf401569c1c23872f435078e73ab81c858c416f44a3869ca383fffd390e731fe7c0512a3cd9cfa7db735f702be1e90a93b99cf46163dc2fe5b601ff36841377ea5c826b771c9c930bdb56c8f220ee53cad04b0c6cf6f037df0ac960c6c79e30406b378c849306168c9222e10b46fbe7243ba2b6befdc277307ae7fd9a377d0d52669f0e2efa6b2664b004bd885d2c03ca3e0740df7b44d6a434ca5031d668e6deb7df4b220c197b4ad2e13b01ff9bf0c18b4b6b1d9ac008fba3e170f6991ea74b798084ea682dd7ef34a25f8ef12d4ec46ac457a06b213ce0dced4c6dd61f14c81710de2141ece60257e5c4208471a858dbda51c1438abdbbb6cbeb50c3eaad46b1771514a2a9ae20ad3e00188f59bdab7e929a84bfe019fbb7fbe5403ed270df1ded79f385d8009c8e2d30aed53d86da0fcad5f7385247516b7c854a1d11ea716961e5ab20df10d472c2b2d7532b98ad6bf6b809fb4fb5ad7f9223b8711fc2d7b8a8dcac7f6b6b38abca2a568b9fc6b45dccb10f7703a1e9f2ab7ac873f41d48740d6a7ef9786aefb625188ac6231e685e04d88c0a22866b9eacb95d83e164ed55f8a7684787077ecb6c5c4642858856480cb89d7f98155ada926ee3b17e784782d5dbab71a326bdef9f1fdbc8af3cdc22557f279999a5d6b4a04a9c293dde7ea811df5733727d018164dae35de9d15a77ef278ef231216227a4609189d77bef15c960a2e001a1d7a23c950b05f6dda499a3b34b24946d5d50b122188595ea7634fe35e7ec2ab9e96656b122ceeef47c7f52282fd38835a91c941a3e9ade814536f320d3204ba4b8577d4bc26eada66bd2e75f2608c8ca6c6d42e7020339474ee80e28e08c43349542cb9b3e0cd856887fe1cc2cd8cf916cf1e8ce35b670f703e38723ef24b0752af034fd48b90b0c6dd309c84dca37c7103d695129eb2bfa27421fa42583a4dc0269e585cdb7d78c9559373de9ef9081393a6ba94fc5a4a6c7d6207406407c3d55782f4e564be49696aa20a13128f</script>
  <div class="hbe hbe-content">
    <div class="hbe hbe-input hbe-input-default">
      <input class="hbe hbe-input-field hbe-input-field-default" type="password" id="hbePass">
      <label class="hbe hbe-input-label hbe-input-label-default" for="hbePass">
        <span class="hbe hbe-input-label-content hbe-input-label-content-default">Hey, password is required here.</span>
      </label>
    </div>
  </div>
</div>
<script data-pjax src="/lib/hbe.js"></script><link href="/css/hbe.style.css" rel="stylesheet" type="text/css">
    </article>
    <!-- license -->
    
        <div class="license-wrapper">
            <p>原文作者：<a href="https://lgsfly.gitee.io">文平夕</a>
            <p>原文链接：<a href="https://lgsfly.gitee.io/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/">https://lgsfly.gitee.io/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/</a>
            <p>发表日期：<a href="https://lgsfly.gitee.io/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/">March 5th 2022, 12:00:00 am</a>
            <p>更新日期：<a href="https://lgsfly.gitee.io/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/">March 6th 2022, 12:25:17 am</a>
            <p>版权声明：本文采用<a rel="license noopener" target="_blank" href="http://creativecommons.org/licenses/by-nc/4.0/">知识共享署名-非商业性使用 4.0 国际许可协议</a>进行许可</p>
        </div>
    
    <!-- paginator -->
    <ul class="post-paginator">
        <li class="next">
            
                <div class="nextSlogan">Next Post</div>
                <a href="/2022/03/05/hello-world/" title="Hello World">
                    <div class="nextTitle">Hello World</div>
                </a>
            
        </li>
        <li class="previous">
            
        </li>
    </ul>
    <!-- comment -->
    
        <div class="post-comment">
            <!-- 来必力 City 版安装代码 -->


            

            

            

            <!-- utteranc评论 -->


            <!-- partial('_partial/comment/changyan') -->
            <!--PC版-->


            
            

            

        </div>
    
    <!-- timeliness note -->
    <!-- idea from: https://hexo.fluid-dev.com/posts/hexo-injector/#%E6%96%87%E7%AB%A0%E6%97%B6%E6%95%88%E6%80%A7%E6%8F%90%E7%A4%BA -->
    
    <!-- Mathjax -->
    
</main>

                <!-- profile -->
                
            </div>
            <footer class="footer footer-unloaded">
    <!-- social  -->
    
        <div class="social">
            
    
        
            
                <a href="mailto:123456@qq.com" class="iconfont-archer email" title=email ></a>
            
        
    
        
            
                <a href="//github.com/lgsfly" class="iconfont-archer github" target="_blank" title=github></a>
            
        
    
        
            
                <span class="iconfont-archer wechat" title=wechat>
                    
                    <img class="profile-qr" src="/assets/qr_code.jpg" />
                </span>
            
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    


        </div>
    
    <!-- powered by Hexo  -->
    <div class="copyright">
        <span id="hexo-power">Powered by <a href="https://hexo.io/" target="_blank">Hexo</a></span><span class="iconfont-archer power">&#xe635;</span><span id="theme-info">theme <a href="https://github.com/fi3ework/hexo-theme-archer" target="_blank">Archer</a></span>
    </div>
    <!-- website approve for Chinese user -->
    
    <!-- 不蒜子  -->
    
        <div class="busuanzi-container">
            
             
                <span id="busuanzi_container_site_pv">PV: <span id="busuanzi_value_site_pv"></span> :)</span>
            
        </div>
    	
</footer>

        </div>
        <!-- toc -->
        
            <div class="toc-wrapper toc-wrapper-loding" style=







    top:50vh;

>
                <div class="toc-catalog">
                    <span class="iconfont-archer catalog-icon">&#xe613;</span><span>CATALOG</span>
                </div>
                
            </div>
        
        <!-- sidebar -->
        <div class="sidebar sidebar-hide">
    <ul class="sidebar-tabs sidebar-tabs-active-0">
        <li class="sidebar-tab-archives"><span class="iconfont-archer">&#xe67d;</span><span class="tab-name">Archive</span></li>
        <li class="sidebar-tab-tags"><span class="iconfont-archer">&#xe61b;</span><span class="tab-name">Tag</span></li>
        <li class="sidebar-tab-categories"><span class="iconfont-archer">&#xe666;</span><span class="tab-name">Cate</span></li>
    </ul>
    <div class="sidebar-content sidebar-content-show-archive">
        <div class="sidebar-panel-archives">
    <!-- 在 ejs 中将 archive 按照时间排序 -->
    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    
    
    
    
    <div class="total-and-search">
        <div class="total-archive">
        Total : 8
        </div>
        <!-- search  -->
        
    </div>
    
    <div class="post-archive">
    
        
            
            
            <div class="archive-year"> 2023 </div>
            <ul class="year-list">
            
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/07</span>
            <a class="archive-post-title" href="/2023/03/07/%E5%B9%B4%E5%88%9D%E6%80%BB%E7%BB%93/">年初总结</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/03</span>
            <a class="archive-post-title" href="/2023/03/03/%E9%9A%8F%E7%AC%94%E4%B8%80/">随笔一</a>
        </li>
    
        
            
            
                
                </ul>
            
            <div class="archive-year"> 2022 </div>
            <ul class="year-list">
            
        
        <li class="archive-post-item">
            <span class="archive-post-date">11/11</span>
            <a class="archive-post-title" href="/2022/11/11/Centos7Wifi/">CentOS7连接Wifi</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">04/15</span>
            <a class="archive-post-title" href="/2022/04/15/SelfVVn/">SelfVVN</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">04/01</span>
            <a class="archive-post-title" href="/2022/04/01/%E4%BA%BA%E9%97%B4%E5%9B%9B%E6%9C%88%E5%A4%A9/">人间四月天</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/09</span>
            <a class="archive-post-title" href="/2022/03/09/CAP/">CAP理论面试考察点</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/05</span>
            <a class="archive-post-title" href="/2022/03/05/hello-world/">Hello World</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/05</span>
            <a class="archive-post-title" href="/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/">开篇</a>
        </li>
    
    </div>
</div>

        <div class="sidebar-panel-tags">
    <div class="sidebar-tags-name">
        
            <span class="sidebar-tag-name" data-tags="操作系统">
                <span class="iconfont-archer">&#xe606;</span>
                操作系统
            </span>
        
            <span class="sidebar-tag-name" data-tags="随笔">
                <span class="iconfont-archer">&#xe606;</span>
                随笔
            </span>
        
    </div>
    <div class="iconfont-archer sidebar-tags-empty">&#xe678;</div>
    <div class="tag-load-fail" style="display: none; color: #ccc; font-size: 0.6rem;">
        缺失模块，请参考主题文档进行安装配置：https://github.com/fi3ework/hexo-theme-archer#%E5%AE%89%E8%A3%85%E4%B8%BB%E9%A2%98
    </div> 
    <div class="sidebar-tags-list"></div>
</div>

        <div class="sidebar-panel-categories">
    <div class="sidebar-categories-name">
    
        <span class="sidebar-category-name" data-categories="随笔">
            <span class="iconfont-archer">&#xe60a;</span>
            随笔
        </span>
    
    </div>
    <div class="iconfont-archer sidebar-categories-empty">&#xe678;</div>
    <div class="sidebar-categories-list"></div>
</div>

    </div>
</div>

        <!-- site-meta -->
        <script>
    var siteMetaRoot = "/"
    if (siteMetaRoot === "undefined") {
        siteMetaRoot = '/'
    }
    var siteMeta = {
        url: "https://lgsfly.gitee.io",
        root: siteMetaRoot,
        author: "文平夕"
    }
</script>

        <!-- import experimental options here -->
        <!-- Custom Font -->


        <!-- main func -->
        <script src="/scripts/main.js?v=20221112"></script>
        <!-- dark mode -->
        <script src="/scripts/dark.js?v=20221112"></script>
        <!-- fancybox -->
        <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.js" defer></script>
        <!-- algolia -->
        
        <!-- busuanzi -->
        
            <script src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js" async></script>
        
        <!-- CNZZ -->
        
        <!-- async load share.js -->
        
            <script src="/scripts/share.js?v=20221112" async></script>
        
        <!-- mermaid -->
        
    </body>
</html>
